

FIG. 1A



FIG. 1B



FIG. 2A



PRIOR-ART #1

FIG. 2B



## PRIOR-ART #2

FIG. 2C



## PRIOR-ART #3

FIG. 2D



PRIOR-ART #4

FIG. 2E



FIG. 3A



FIG. 3B



FIG. 3C



FIG. 4A



FIG. 4B



FIG. 4C



FIG. 4D



FIG. 4E



FIG. 4F



FIG. 4G



FIG. 4H



FIG. 4I



FIG. 4J

| Original                                                                                                                                        | Modified                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>input rst, x, d, ck; wire s_rst, c_rst; reg z, q1, q2;  assign s_rst = rst &amp; z; assign c_rst = rst &amp; x; always @(posedge ck)</pre> | // Added to repair combinational gated reset. assign scan_c_rst = ~(SE   ~SR_EN) & c_rst; assign s_rst = rst & z; assign c_rst = rst & x; always @(posedge ck) |

| Original                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>2     wire d_rst; 3     reg g_rst, q1, q2; 4 5     assign d_rst = 1; 6     always @(posedge ck) 7         g_rst &lt;= x; 8 9     // g_rst is generated reset. 10     always @(posedge ck or posedge g_rst) 11     if (g_rst) 12         q1 &lt;= 0; 13     else 14         q1 &lt;= d; 15 16     // d_rst is destructive reset. 17     always @ (posedge ck or posedge d_rst) 18     if (d_rst) 19         q2 &lt;= 0; 20     else 21         q2 &lt;= d; 22 23 24 25</pre> | <pre>input x, d, ck, SE, SR_EN; wire d_rst; reg g_rst, q1, q2;  // Added for repair. wire scan_g_rst; wire scan_d_rst;  // Added to repair generated reset. assign scan_g_rst = ~(SE   ~SR_EN) &amp; g_rst; // Added to repair destructive reset. assign scan_d_rst = ~(SE   ~SR_EN) &amp; d_rst; assign d_rst = 1; always @(posedge ck)     g_rst &lt;= x;  // Modified to repair generated reset. always @(posedge ck or posedge scan_g_rst)     if (scan_g_rst)         q1 &lt;= 0; else     q1 &lt;= d;  // Modified to repair destructive reset. always @(posedge ck or posedge scan_d_rst)     if (scan_d_rst)         q2 &lt;= 0; else         q2 &lt;= d;</pre> |



FIG. 5C



FIG. 5D



FIG. 5E



FIG. 5F



FIG. 6





FIG. 7B



FIG. 8